package com.sky.mapper;

import com.sky.entity.OrderDetail;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 订单明细Mapper接口
 */
@Mapper
public interface OrderDetailMapper {

    /**
     * 批量插入订单项
     * @param orderDetails 订单项列表
     */
    void insertBatch(List<OrderDetail> orderDetails);
    
    /**
     * 根据订单ID查询订单项
     * @param orderId 订单ID
     * @return 订单项列表
     */
    @Select("select * from order_detail where order_id = #{orderId}")
    List<OrderDetail> getByOrderId(Long orderId);
    
    /**
     * 根据订单ID批量删除订单项
     * @param orderIds 订单ID列表
     */
    void deleteByOrderIds(List<Long> orderIds);
    
    /**
     * 根据套餐ID查询对应的订单项数量
     * @param setmealId 套餐ID
     * @return 订单项数量
     */
    @Select("select count(*) from order_detail where setmeal_id = #{setmealId}")
    Integer countBySetmealId(Long setmealId);
    
    /**
     * 根据菜品ID查询对应的订单项数量
     * @param dishId 菜品ID
     * @return 订单项数量
     */
    @Select("select count(*) from order_detail where dish_id = #{dishId}")
    Integer countByDishId(Long dishId);
}